//请实现一个函数，用来判断一棵二叉树是不是对称的。如果一棵二叉树和它的镜像一样，那么它是对称的。 
//
// 例如，二叉树 [1,2,2,3,4,4,3] 是对称的。 
//
// 1 
// / \ 
// 2 2 
// / \ / \ 
//3 4 4 3 
//但是下面这个 [1,2,2,null,3,null,3] 则不是镜像对称的: 
//
// 1 
// / \ 
// 2 2 
// \ \ 
// 3 3 
//
// 
//
// 示例 1： 
//
// 输入：root = [1,2,2,3,4,4,3]
//输出：true
// 
//
// 示例 2： 
//
// 输入：root = [1,2,2,null,3,null,3]
//输出：false 
//
// 
//
// 限制： 
//
// 0 <= 节点个数 <= 1000 
//
// 注意：本题与主站 101 题相同：https://leetcode-cn.com/problems/symmetric-tree/ 
// Related Topics 树 
// 👍 53 👎 0

package leetcode.editor.cn;

import leetcode.editor.commons.TreeNode;

//Java：对称的二叉树
public class PJzOffer28DuiChengDeErChaShuLcof{
    public static void main(String[] args) {
        Solution solution = new PJzOffer28DuiChengDeErChaShuLcof().new Solution();
        // TO TEST
    }
    //leetcode submit region begin(Prohibit modification and deletion)
/**
 * Definition for a binary tree node.
 * public class TreeNode {
 *     int val;
 *     TreeNode left;
 *     TreeNode right;
 *     TreeNode(int x) { val = x; }
 * }
 */
class Solution {
    /*
    左子树的左节点与右子树的右节点相同
    * */
    public boolean isSymmetric(TreeNode root) {
        if(root==null){
            return true;
        }

        return isSym(root.left,root.right);
    }

    public boolean isSym(TreeNode left,TreeNode right){
        if(left==null&&right==null){
            return true;
        }
        if(left==null||right==null){
            return  false;
        }
        if(left.val!=right.val){
            return false;
        }
        return isSym(left.left,right.right)&&isSym(left.right,right.left);
    }


}
//leetcode submit region end(Prohibit modification and deletion)

}
